<template>
  <Dialog :title="dialogTitle" v-model="dialogVisible">
    <el-form ref="formRef" size="large" :model="formData" :rules="formRules" label-width="120px"
      v-loading="formLoading">

      <el-form-item label="设备名称" prop="equipmentId">
        <el-select :loading="remortLoading" remote :remote-method="remoteSearch" clearable filterable
          v-model="formData.equipmentId" placeholder="请输入关键字搜索,支持设备名称、编码、安装位置">
          <el-option v-for="dict in EquipmentList" :key="dict.id"
            :label="`${dict.equipmentName} - ${dict.code} - ${dict.installPosition}`" :value="dict.id" />
        </el-select>
      </el-form-item>


      <el-form-item label="维护分类" prop="itemId">
        <el-select clearable filterable v-model="formData.itemId" placeholder="请选择维护分类">
          <el-option v-for="dict in keepSettingType" :key="dict.id" :label="dict.name" :value="dict.id" />
        </el-select>
      </el-form-item>



      <el-form-item label="计划维护日期" prop="planDate">
        <el-date-picker v-model="formData.planDate" type="date" value-format="YYYY-MM-DD" placeholder="选择计划维护日期" />
      </el-form-item>
    </el-form>
    <template #footer>
      <el-button @click="submitForm" type="primary" :disabled="formLoading">确 定</el-button>
      <el-button @click="dialogVisible = false">取 消</el-button>
    </template>
  </Dialog>
</template>
<script setup lang="ts">
import { EquipmnetKeepWaitApi, EquipmnetKeepWait } from '@/api/business/equipmnetkeepwait'
import { EquipmentManageApi, EquipmentManage } from '@/api/business/equipmentmanage'
import { EquipmentKeepSettingTypeApi, EquipmentKeepSettingType } from '@/api/business/equipmentkeepsettingtype'


/** 待维护设备 表单 */
defineOptions({ name: 'EquipmnetKeepWaitForm' })

const { t } = useI18n() // 国际化
const message = useMessage() // 消息弹窗

const dialogVisible = ref(false) // 弹窗的是否展示
const dialogTitle = ref('') // 弹窗的标题
const formLoading = ref(false) // 表单的加载中：1）修改时的数据加载；2）提交的按钮禁用
const formType = ref('') // 表单的类型：create - 新增；update - 修改
const formData = ref({
  id: undefined,
  keepNo: undefined,
  itemId: undefined,
  equipmentId: undefined,
  status: undefined,
  planDate: undefined,
  remaining: undefined,
  dutyUserId: undefined,
  dutyUserName: undefined
})
const formRules = reactive({
  itemId: [{ required: true, message: '维护项id不能为空', trigger: 'change' }],
  equipmentId: [{ required: true, message: '设备不能为空', trigger: 'change' }],
  planDate: [{ required: true, message: '计划维护日期不能为空', trigger: 'blur' }]
})
const formRef = ref() // 表单 Ref

const queryParams = reactive({
  pageNo: 1,
  pageSize: 100,
  keepNo: undefined,
  itemId: undefined,
  equipmentId: undefined,
  status: undefined,
  dutyUserName: undefined,
  equipmentName: undefined
})


/** 打开弹窗 */
const open = async (type: string, id?: number) => {
  await initData()
  dialogVisible.value = true
  dialogTitle.value = t('action.' + type)
  formType.value = type
  resetForm()
  // 修改时，设置数据
  if (id) {
    formLoading.value = true
    try {
      formData.value = await EquipmnetKeepWaitApi.getEquipmnetKeepWaitDamage(id)
    } finally {
      formLoading.value = false
    }
  }
}


defineExpose({ open }) // 提供 open 方法，用于打开弹窗

//设备列表
const EquipmentList = ref([])

//维护分类
const keepSettingType = ref([])

const remortLoading = ref(false)

const remoteSearch = async (query) => {
  console.log("?????", query);
  remortLoading.value = true
  let params = {
    keyWords: query
  }
  EquipmentList.value = await EquipmentManageApi.getEquipmentManageList(params)
  remortLoading.value = false
}

const initData = async () => {
  const data = await EquipmentKeepSettingTypeApi.getEquipmentKeepSettingTypePageDamage(queryParams)
  keepSettingType.value = data.list
}

/** 提交表单 */
const emit = defineEmits(['success']) // 定义 success 事件，用于操作成功后的回调
const submitForm = async () => {
  // 校验表单
  await formRef.value.validate()
  // 提交请求
  formLoading.value = true
  try {
    const data = formData.value as unknown as EquipmnetKeepWait
    if (formType.value === 'create') {
      await EquipmnetKeepWaitApi.createEquipmnetKeepWaitDamage(data)
      message.success(t('common.createSuccess'))
    } else {
      await EquipmnetKeepWaitApi.updateEquipmnetKeepWaitDamage(data)
      message.success(t('common.updateSuccess'))
    }
    dialogVisible.value = false
    // 发送操作成功的事件
    emit('success')
  } finally {
    formLoading.value = false
  }
}

/** 重置表单 */
const resetForm = () => {
  formData.value = {
    id: undefined,
    keepNo: undefined,
    itemId: undefined,
    equipmentId: undefined,
    status: undefined,
    planDate: undefined,
    remaining: undefined,
    dutyUserId: undefined,
    dutyUserName: undefined
  }
  formRef.value?.resetFields()
}
</script>
